## FPGA MGT builder

A. Madorsky, University of Florida/Physics 2020-04-29

FPGA MGT builder is a set of software tools with the following functionality:

- Automatic generation of firmware structure with support for arbitrary MGT configurations. This includes:
  - o Different bit rates and encodings in RX and TX parts of the same MGT
  - Using CPLL and QPLL as needed for each MGT, programmable separately for RX and TX parts (within the constraints of the particular FPGA architecture)
  - o Automatic routing and assignment of available reference clocks for each MGT
  - Grouping MGTs into interfaces with programmable names and indexes, which makes using them in the top-level design much easier
  - Automatic generation of all constraints related to MGTs
    - Reference clock location, timing, and grouping
    - MGT location
    - User clock timing
  - The software is designed to make porting a project to different board design or FPGA an easy task.
  - o Targeting lowest-latency serial links, by disabling RX and TX buffers
- Software framework:
  - Reads configuration settings and programs all DRP registers and port settings in each MGT and COMMON modules
  - Customizable reset procedures, with main functionality provided in the example design
  - Written in portable C++, can be adapted for nearly any system, including embedded processors
  - o Does not need rework if the MGT configuration is changed
- Configuration sources:
  - All source configuration files are kept in Excel XLSX format
    - Makes working with them much easier
  - Data format is optimized for direct copying from Xilinx manuals and example source code, with minimal manual rework
  - A Python script is provided for exporting configuration files into plain text
- Currently supported:
  - System Verilog HDL
  - Linux
  - Xilinx 7-series FPGAs, GTH transceivers
    - Ultrascale support is coming soon
- Software needed:
  - Java run-time for running unmodified MGT firmware generator (provided as JAR archive)

- o Eclipse and Java compiler if you want to recompile the firmware generator
- o C++ compiler
- o Python 3
- Languages used:

Firmware generator: Java
 Software framework: C++
 Configuration exporter: Python

### Getting started

The easiest way to familiarize yourself FPGA MGT builder is to use the example configuration provided with the software. The examples provide full support for the following FPGA:

XC7VX690T-FFG1927

Step by step instructions:

- 1. Download the entire package from Github
- 2. Go into examples directory
- 3. There are three example projects provided. Each project is a directory. Make a copy of one of them, keeping internal directory structure.
- 4. Go inside the new project directory, src subdirectory
- 5. This directory contains all source files in Excel format
  - a. Protocols.xlsx contains user's protocol settings
  - b. MTF7.xlsx contains settings related to a particular board which is used in this project. A project can be used on multiple boards.
  - xc7vx690tffg1927-2\_GTH.x1sx file contains settings related to a particular FPGA and MGT family used in this project. A project can be used on multiple FPGAs and MGT families
- 6. At this time, you only need to modify protocols.xlsx. Open this file in LibreOffice Calc
- 7. Click on a tab named "EMTF\_links". This is the list of all RX and TX links to be used in the design. Columns in that file are shown below:

| Column | Description                                                            |
|--------|------------------------------------------------------------------------|
| number |                                                                        |
| 1      | Link type, tx or rx                                                    |
| 2      | MGT X coordinate                                                       |
| 3      | MGT Y coordinate                                                       |
| 4      | Protocol name, must match one of the available protocols. See          |
|        | protocols directory for the available protocols.                       |
| 5      | QPLL or CPLL used (Q and C respectively)                               |
| 6      | Reference clock frequency, in MHz. May contain decimal point           |
| 7      | Link group name, arbitrary. Will be used in the generated code as      |
|        | interface name                                                         |
| 8      | Link group index. Indexes within each group must start from 0, and run |
|        | contiguously, without gaps.                                            |

- 8. Modify the Link table as needed. For example, try changing some of the protocol names, or MGT coordinates. Make sure to use valid coordinates and existing protocols.
- 9. When done, save the file.
- 10. Export the spreadsheet into text format:
  - a. Go back into the top project directory, for example: mgt builder/examples/MPCX
  - b. Issue the following command:
     python3 ../../python/xls\_to\_txt\_openpyxl.py src/protocols.xlsx
  - c. This procedure automatically exports the contents of the XLSX file into text files and puts them into appropriate directories within the project.
- 11. In the project directory, find a file that has "root" in the name. This is your main configuration file (also exported from protocols.xlsx). For example, in MPCX project the file is named: EMTF\_MPCX\_root.tab
- 12. Generate firmware:
  - java -jar ../../java/mgt builder.jar EMTF MPCX root.tab
- 13. Visit "sv" directory and inspect the generated files. The list of generated files is shown below:

| File name                     | Description                                         |
|-------------------------------|-----------------------------------------------------|
| <pre>mpcx_serial_io.sv</pre>  | Top-level module                                    |
| quad_module.sv                | Quad module                                         |
| mgt_module.sv                 | MGT module                                          |
| common_module.sv              | COMMON module                                       |
| assign_mgt_rx.sv              | RX interface assignment module                      |
| assign_mgt_tx.sv              | TX interface assignment module                      |
| mgt_interfaces.sv             | Interface definitions. When importing into Vivado,  |
|                               | mark this file as Verilog header                    |
| xymap.sv                      | X-Y coordinate map of the MGTs. When importing into |
|                               | Vivado, mark this file as Verilog header            |
| <pre>mpcx_serial_io.xdc</pre> | Constraint file                                     |

- 14. The names of the generated files and the top SystemVerilog module are programmable via "root\_config" tab in protocols.xlsx file. If you modifly any of them, don't forget to export XLSX file into text as shown in step 10.
- 15. Import the generated files into your Vivado design.
- 16. Also import files from sv\_manual directory. This is a supporting logic for DRP and port access. Do not modify files in sv\_manual directory.
- 17. In your Vivado project:
  - a. MGT builder currently generates a place-holder for MMCM to manage the shared TX clocks. They need to be replaced with BUFGs as shown below:

Generated code example:

```
MPCX_mmcm MPCX_15_inst (.O(MPCX_15_mmcm_clk), .I(mgt_tx_if[0][0].txoutclk));
Reworked code example:
```

```
BUFG MPCX_15_inst (.O(MPCX_15_mmcm_clk), .I(mgt_tx_if[0][0].txoutclk));
```

- i. There may be several lines like this depending on your configuration.
- b. Instantiate the generated top-level module in your design. Make sure to connect reference clocks and DRP bus signals.
- c. Reference clocks should propagate to top-level module header unchanged.
- d. DRP bus signals should be generated from your control interface. The generated firmware requires only 64KB of address space; this number does not depend on the number of MGTs in the design.
- e. Instantiate TX and RX interfaces to be connected to the generated module. See top-level generated module declaration for details. Connect these interfaces to generated top-level module, and to your firmware module(s) that work with MGTs.

#### RX interface details

FPGA MGT builder is targeted for lowest serial link latency. RX logic is generated with the assumption that the RX buffers are disabled. Therefore, each RX interface comes with its own data clock, buffered via BUFH. The name of that clock is rxoutclk. The user is expected to take care about clock domain crossing from rxoutclk of each MGT to the common fabric clock.

#### TX interface details

TX logic is also generated with the assumption that TX buffers are disabled. However, at this time the examples are set up for using TX buffers. This does not add a lot of latency (typically 2 XCLK periods). However, the work is ongoing to fully support disabling TX buffers.

As recommended by Xilinx manual, in the generated firmware the TX clock is shared between MGTs that:

- Are using the same protocol
- Are using the same reference clock input

These shared clocks are presented as outputs of the generated top-level module. The names for them are constructed as follows:

Where "MPCX" is the protocol name, and "15" is the reference clock index. The user must make sure to use each TX clock with TX interfaces from corresponding MGTs. Identifying which MGT belongs to which TX clocks is easy:

- Open top-level generated module code
- Find a section with TX clock assignment (at the bottom)
- The comments at the end of each assignment line show interface name and MGT index The user is expected to take care about clock domain crossing from the common fabric clock to each of the TX clocks.

# Using and adapting C++ software for your design TBD